

# Design of Linear Feedback Shift Register using Reversible Logic

Sree Ramani Potluri<sup>1</sup>, Lipsa Dash<sup>2</sup>

Sr. Asst. Prof, Department of ECE, New Horizon College of Engineering, Bangalore<sup>1</sup>

Asst. Prof, Department of ECE, New Horizon College of Engineering, Bangalore<sup>2</sup>

**Abstract:** Reversible logic is playing an important role in research areas and has found its applications in low power CMOS VLSI, Nanotechnology and Quantum computation. Recently, several researchers have focused their efforts on the design and synthesis of efficient reversible logic circuits. LFSR's are attractive structures in the area of digital system testing and fault tolerant computing. In this work, we present designs of reversible LFSR using D flip flops with asynchronous set/reset. The comparison of proposed design is done in terms of the quantum cost, delay and garbage out puts. The important reversible gates used for Reversible logic design are Feynman gate, Fredkin gate, Toffoli gate, SAM gate etc.

Keywords: Low-power VLSI, Low-power CMOS design, reversible logic, LFSR.

### **1. INTRODUCTION**

Energy loss is an important consideration in digital circuit design, also known as circuit synthesis. With the number of chip components doubling every 18 months, as per Moore's Law, the Irreversible Technologies would dissipate a lot of heat and reduce circuit life. It is here the Reversible Logic comes into action in not only recovering the lost information but also dissipating less heat. Landauers principle states that logic computations that are not reversible necessarily generates KT\*log2 joules of heat energy for every bit of information that is lost, where k is the Boltzmann's constant and T is the absolute temperature at which the computation is performed. For room temperature T, the amount of dissipating heat is small (2.9x10-21 joules) but not negligible [1].

Bennett showed that KTln2 energy dissipation would not occur if computation is carried out in a reversible way [2]. In the year 1994 Shor [5] did a remarkable research work in creating an algorithm using reversibility for factorizing large number with better efficiency when compared to the classical computing theory. After this the work on reversible computing has been started by more people in different fields such as nanotechnology, quantum computers and CMOS VLSI.

Reversible logic is being considered as an alternative of traditional irreversible logic as reversible computing does not erase or lose any information hence the reversible logic has a theoretical potential to dissipate no energy. Reversible circuits are designed using reversible logic gates that have the same number of inputs and outputs and have one-to-one mapping between inputs and outputs; thus, the input states can be always reconstructed from the output states [7]. A gate (circuit) is reversible if it maps each input assignment to a unique output assignment, that is, if the mapping of inputs to outputs is bijective. Thus, the number of inputs and outputs in a reversible gate or circuit are equal. The N\*N reversible gate can be represented as shown in Figure 1.



Recently, the design of reversible sequential circuits has also attracted the attention of researchers such as the work in [4, 9, 12, 13].

The paper is organized as follows: Section 2 presents the basic definitions related to reversible gates; Section 3 presents the basic reversible gates and their quantum representation; Section 4 presents the design of asynchronous set/reset D- FF using Fredkin Gates and SAM gates Section 5 presents the Design of LFSR using reversible logic and comparisons of the proposed designs; Section 6 presents the conclusions.

#### 2. BASIC DEFINITIONS RELATED TO REVERSIBLE LOGIC

**Definition 2.1**: The function f(x1, x2 ... xn) of n Boolean variables is called reversible if:

1. The number of outputs is equal to the number of inputs. 2. Any input pattern maps to a unique output pattern. In other words, the output of a reversible function is a permutation of the set of its inputs [14].

**Definition 2.2:** For an (n, k) function, i.e. function with ninput k-output, it is necessary to add inputs and/or outputs to make it reversible. "Garbage" is the number of outputs added to make an (n, k) function reversible. While the word "constant inputs" is used to denote the pre-set value



inputs that were added to an (n, k) function to make it 3) Double Feynman Gate: reversible. The constant inputs are known as ancillary The double Feynman gate is 3\*3 reversible gate having inputs [14]. The relation between garbage outputs and inputs (A, B, C) and outputs P=A,Q=A XOR B, R=A constant inputs is

Input + constant input= output + garbage

Definition 2.3: Quantum cost refers to the cost of the circuit in terms of the cost of a primitive gate. It is calculated knowing the number of primitive reversible logic gates (1\*1 or 2\*2) required to realize the circuit. The quantum cost of a circuit is the minimum number of 2\*2 unitary gates to represent the circuit keeping the output unchanged. The quantum cost of a 1\*1 gate is 0 and that of any 2\*2 gate is the same, which is 1 [18].

**Definition 2.4:** The Delay of a Reversible Logic Gate is the maximum number of gates in a path from any input line to its corresponding output line.

### **3. BASIC REVERSIBLE LOGIC GATES**

There are many number of reversible logic gates that exist at present. The quantum cost of each reversible logic gate is an important optimization parameter [16]. The quantum cost of a 1x1 reversible gate is assumed to be zero while the quantum cost of a 2x2 reversible logic gate is taken as unity. The quantum cost of other reversible gates is calculated by counting the number of V, V<sup>+</sup> and CNOT gates present in their circuit. V is the square root of NOT gate and  $V^+$  is its Hermitian. The V and  $V^+$  quantum gates have the following properties:

| V * V = NOT             | (1) |
|-------------------------|-----|
| $V * V^+ = V^+ * V = 1$ | (2) |
| $V^{+} * V^{+} = NOT$   | (3) |

Some of the important reversible logic gates are 1) NOT Gate

The simplest Reversible gate is NOT gate and is a 1\*1 gate [7]. The Reversible 1\*1 gate is NOT Gate with zero Quantum Cost.It is as shown in the Figure 3.1 Input Vector = A, Output Vector=A'





Figure 3.1

### 2) CNOT /Feynman Gate:

Feynman gate [17]is also known as controlled-not gate (CNOT). It is a 2\*2 reversible gate with Quantum cost of 1. The CNOT or Feynman gate can be described as: Input Vector = (A, B) Output Vector=A XOR B As shown in Figure 3.2



Figure 3.2

XOR C with a quantum cost of 2[8]. The double Feynman can be described as:



# 4) TOFFOLI Gate:

TOFFOLI gate which is a 3\*3 reversible gate with inputs (A, B, C) and outputs P=A, Q=B, R=AB XOR C. It has Quantum cost five [5].



# 5) PERES Gate:

Peres gate which is a 3\*3 reversible gate having inputs (A, B, C) and outputs P = A; Q = A XOR B; R = AB XOR C. It has Quantum cost four [6].



### 6) FREDKIN Gate:

Fredkin gate is a 3\*3 reversible gate with inputs (A, B, C) and outputs P=A, Q=A'B+AC, R=AB+A'C. It has Quantum cost five [6].



# 7) SAM Gate:

SAM gate is a 3\*3 reversible gate with inputs A, B, C and outputs P=A', Q=A'B XOR AC', R=A'C XOR AB.The quantum cost of SAM gate is 4[3].



Copyright to IJARCCE

#### DOI 10.17148/IJARCCE.2015.412137



#### 4. DESIGN OF MASTER SLAVE D FF WITH ASYNCHRONOUS SET/ RESET

# 4.1The Master-Slave D FF with asynchronous Set/Reset using Fredkin and Feynman gates:

The characteristic equation of gated D flip-flop is **Q=CLK'.Q** +**CLK.D**. The D flip-flop can be realized by one Fredkin gate and one FG. It can be mapped with Fredkin gate by giving CLK, D and Q respectively in 1st, 2nd and 3rd inputs of Fredkin gate [18]. The D FF can be modified as master slave FF [18]. This is further modified with asynchronous Set/Reset as shown in figure 4.1. In this design the first two Fredkin gates with CLK,D inputs implement the logic for master slave FF. The Fredkin gate used in master latch is the positive enable reversible D Latch, and the Fredkin gate used in Slave latch is the negative enable reversible D Latch .The Fredkin gate with inputs C<sub>1</sub>, C<sub>2</sub> is used to provide the asynchronous set and reset as proposed. The Fredkin gate can be used to avoid the fan out of a signal by assigning that signal to its input A and other two inputs B and C with the inputs B=0 and C=1 as shown in figure 4.2(a).







#### Figure 4.1.2

The Fredkin gate can be used to asynchronously reset its Q & R output's to 0 by assigning the values of 0 to inputs B and C as shown in figure 4.2(b). As shown in figure 4.2(c) by assigning 1 to B and C inputs of Fredkin gate it can asynchronously set its Q and R output to 1. The quantum cost of the DFF with asynchronous set/reset discussed is 17. In our delay calculations, we use the logical depth as measure of the delay [Mohammadi and Eshghi 2009][11]. The delay of each 1x1 gate and  $2\times2$  reversible gate is taken as unit delay called  $\Delta$ . Any 3×3 reversible gate can be designed from  $1 \times 1$  reversible gates and  $2 \times 2$  reversible gates, such as CNOT gate, Controlled-V and Controlled- $V^+$ gates. Thus, the delay of a 3×3 reversible gate can be computed by calculating its logical depth when it is designed from smaller  $1 \times 1$  and  $2 \times 2$  reversible gates [6],[10],[15]. The SAM gate, the Fredkin gate, Toffoli gate are the three major  $3 \times 3$  reversible gates used in this work for designing the DFF circuits, thus in this section we calculate the delays of the Fredkin gate, SAM gate and Toffoli Gate. Based on the logical depth the delay of SAM gate is 4 $\Delta$ , and Fredkin gate and Toffoli gate is 5 $\Delta$ .The designed asynchronous D FF involves 3 Fredkin gates, 2

Feynman gates, so the delay is  $17\Delta$ . The number of garbage outputs for the proposed design are 5. The designed Master –Slave D FF with asynchronous Set/Reset can be represented with a symbol as shown in the figure 4.5(b).

# **4.2** The Master-Slave D FF with asynchronous Set/Reset from SAM, Toffoli and Feynman gates:

The characteristic equation of gated D flip flop can be realized by one SAM Gate and one Feynman Gate, where the inputs CLK, D, Q are mapped to 1<sup>st</sup>, 2nd and 3<sup>rd</sup> inputs of SAM gate [3]. The D FF is modified as Master Slave FF with asynchronous Set/Reset as shown in the Figure 4.2.1. In this design, the two SAM gates are used to provide the necessary logic for implementation of master slave logic and the Toffoli gate with inputs C<sub>1</sub>, C<sub>2</sub> is used to provide the asynchronous set and reset, as described below. The Toffoli gate can be used to avoid the fan out of a signal by assigning that signal to its input B and other two inputs A and C with the inputs A=1 and C=0 as shown in figure 4.2.2(a)



The Toffoli gate can be used to asynchronously reset its Q & R output's to 0 by assigning the values of 0 to inputs A and C as shown in figure 4.2.2(b). As shown in figure 4.2.2(c) by assigning 0 to A and 1 to C inputs of Toffoli gate it can asynchronously set its R output to 1.The quantum cost of the DFF discussed is 15. The ,designed asynchronous D FF involves 2 SAM gates, 1 Toffoli gate, 2 Feynman gates, so taking the logical depth into consideration the delay is  $15\Delta$ . The number of garbage outputs for the proposed design is 5.The designed Master –Slave D FF with asynchronous Set/Reset can be represented with a symbol as shown in the figure 4.5(b)





# 5. DESIGNING LFSR USING REVERSIBLE LOGIC

A linear feedback shift register (LFSR) consists of N registers connected together as a shift register. The input to the shift register comes from XOR of particular bits of the register. On reset, the registers must be initialized to a non-zero value. The LFSR is an example of a maximal length shift register because its output sequence through all 2<sup>n</sup>-1 combinations (excluding all 0's). The inputs fed to the XOR are called the tap sequence and are often specified with a characteristic polynomial. We in this paper proposes two designs of 3 bit LFSRwith the characteristic polynomial  $1+x^2+x^3$ . LFSRs are used for high speed counters and Pseudo-random number generators. This pseudo random sequence are handy for built-in self-test and bit error rate testing in communication links. They are also used in many spread spectrum communications systems such as GPS and CDMA where their correlation properties make other users look like uncorrelated noise. The following table lists characteristic polynomials for some commonly used maximal length LFSR's

Characteristic Polynomials

| Ν | Polynomial                |
|---|---------------------------|
| 3 | $1+x^2+x^3$               |
| 4 | $1+x^3+x^4$               |
| 5 | $1+x^3+x^5$               |
| 6 | $1+x^5+x^6$               |
| 7 | $1+x^{6}+x^{7}$           |
| 8 | $1 + x + x^6 + x^7 + x^8$ |
| 9 | $1+x^5+x^9$               |

#### Table 5.1

The proposed design of LFSR is shown in the figure 5.1. The design uses D FF's and Feynman gate. The designed LFSR in the first proposal use Master Slave D FF with asynchronous Set/Reset designed from Fredkin gates and Feynman gates as proposed in the section 4.1 named as Fredkin D FF. The designed LFSR for the second proposal make use of Master Slave D FF with asynchronous Set/Reset designed from SAM gates, Toffoli gates and Feynman gates as proposed in the section 4.2 named as SAM D FF. In both the designs Feynman gate is used to avoid fan-out.



The 3-Bit LFSR with Characteristic polynomial 1+x<sup>2</sup>+x<sup>3</sup> Figure 5.1 The Feynman gates are used to overcome fan-out for CLK and output Q0, Q1, Q2. The values provided to the inputs C1, C2force the FF's to either set or Reset condition. On reset, the Flip Flop's must be initialized to a non-zero value. If all the 3 FF's are set to 1 i.e., Q0Q1Q2=111 then designed LFSR will go through the count as shown in the table 5.2. The proposed two designs are compared in terms of quantum cost, delay and garbage outputs as shown in table 5.3 and 5.4.

| LFSR | Seq | uence |
|------|-----|-------|
|      |     |       |

| Cvcle           | 00 | 01 | 02 |
|-----------------|----|----|----|
| 0               | 1  | 1  | 1  |
| 1               | 0  | 1  | 1  |
| 2               | 0  | 0  | 1  |
| 3               | 1  | 0  | 0  |
| 4               | 0  | 1  | 0  |
| 5               | 1  | 0  | 1  |
| 6               | 1  | 1  | 0  |
| 7               | 1  | 1  | 1  |
| Repeats forever |    |    |    |

Table 5.2

A comparison of Master Slave D FF with asynchronous Set/Reset

| Proposed design    | Quantum | Delay | Garbage |
|--------------------|---------|-------|---------|
|                    | cost    |       | Output  |
| Fredkin gate based | 17      | 17    | 5       |
| SAM gate based     | 15      | 15    | 5       |

| Table 5.3 |  |
|-----------|--|
|-----------|--|

A comparison of 3 bit LFSR of the characteristic polynomial  $1\!+\!x^2\!+\!x^3$ 

| Proposed design    | Quantum | Delay | Garbage |
|--------------------|---------|-------|---------|
|                    | cost    |       | Output  |
| Fredkin gate based | 58      | 58    | 16      |
| SAM gate based     | 52      | 52    | 16      |

Table 5.4

The proposed circuit can be used as a Pseudo random bit sequence generator where Q2 is considered as the output from the circuit, in this case the Feynman gates used to avoid fan out of Q0 and Q1 can be removed. The sequence generator is shown in the figure 5.2. The output Q2 follows the sequence 1110010 for the example considered earlier.



Pseudo-random bit sequence generator





### 6. CONCLUSION

In this work, we have presented novel designs of reversible D FF with asynchronous set/reset which are optimized in terms of quantum cost, delay and garbage outputs. We conclude that the choice of reversible gates and the design approach to carefully select a reversible gate for implementing a particular logic function will significantly impact the quantum cost, delay and garbage outputs of the reversible design. The application of these FF's as LFSR is designed and discussed. The application of LFSR as pseudo random bit sequence generator is proposed .Further advancement of the proposed work is to use the proposed D FF's towards the designs of complex reversible sequential circuits such as FSM.

#### REFERENCES

- R. Landauer. Irreversibility and heat generation in the computational process. IBM J. Research and Development, 5:183– 191, Dec. 1961.
- [2] Bennett C.H., "Logical reversibility of Computation", IBM J.Research and Development, pp. 525-532, 1973.
- [3] Md. Selim Al Mamun, David Menville Quantum Cost Optimization for Reversible Sequential Circuit, International Journal of Advanced Computer Science and Applications
- [4] H. Thapliyal, M. B. Srinivas, and M. Zwolinski. A beginningin the reversible logic synthesis of sequential circuits. In Proc. the Military and Aerospace Programmable Logic Devices Intl. Conf., Washington, Sept. 2005.
- [5] E. Fredkin and T. Toffoli. Conservative logic. International J. Theor. Physics, 21:219–253, 1982.
- [6] W. N. Hung, X. Song, G.Yang, J.Yang, and M. Perkowski.Optimal synthesis of multiple output boolean functions using set of quantum gates by symbolic reachability analysis.IEEE Trans. Computer-Aided Design, 25(9):1652–1663,Sept. 2006.
- [7] B.Raghu kanth, B.Murali Krishna, M. Sridhar, V.G. Santhi Swaroop —A DISTINGUISH BETWEEN REVERSIBLE AND CONVENTIONAL LOGIC GATES I, International Journal of Engineering Research and Applications (IJERA) ISSN: 2248-9622 www.ijera.com Vol. 2, Issue 2,Mar-Apr 2012, pp.148-151
- [8] Perkowski, M., "A hierarchical approach to computer-aided design of quantum circuits", 6th International Symposium on Representations and Methodology of Future Computing Technology, 201-209, 2003
- [9] M.-L. Chuang and C.-Y. Wang. Synthesis of reversible sequential elements. J. Emerg. Technol. Comput. Syst., 3(4):1–19, 2008.
- [10] D. Maslov and D. M. Miller. Comparison of thecost metrics for reversible and quantum logic synthesis. http://arxiv.org/abs/quantph/0511008, 2006.
- [11] M. Mohammadi and M. Eshghi. On figures of merit in reversibleand quantum logic designs. Quantum Information Processing, 8(4):297–318, Aug. 2009.
- [12] J. E. Rice. An introduction to reversible latches. Comput. J.,51(6):700–709, 2008.
- [13] S.K.Sastry, H.S.Shroff, S. N. Mahammad, and V. Kamakoti. Efficient building blocks for reversible sequential circuit design. In Proc. the 49th IEEE Intl. 1 Midwest Symp.on Cir. and Sys., pages 437–441, Puerto Rico, Aug. 2006.
- [14] Raghava Garipelly, P.Madhu Kiran, A.Santhosh Kumar, "A Review on Reversible Logic Gates and their Implementation", International Journal of Emerging Technology and Advanced Engineering Volume 3, Issue 3,March 2013
- [15] Prashant R. Yelekar and Prof. Sujata S. Chiwande "Design of sequential circuit using reversible logic", IEEE International Conference on Advances in Engineering, Science And Management (ICAESM -2012) March 30, 31, 2012
- [16] M. Mohammadi and M. Eshghi. On figures of merit in reversible and quantum logic designs. Quantum Information Processing, 8(4):297–318, Aug. 2009.
- [17] Richard P.Feynman, "Quantum mechanical computers," Foundations of Physics, vol. 16, no. 6, pp. 507-531, 1986.

- [18] H.Thapliyal and N. Ranganathan, Design of reversible sequential circuits optimizing quantum cost, delay and garbage outputs, ACM Journal of Emerging Technologies in Computing Systems, vol. 6, no.4, Article 14, pp. 14:1–14:35, Dec. 2010
- [19] P. Shor, Algorithms for quantum computation: discrete log and factoring, Proc. 35th Annual Symp. On Found. Of Computer Science (1994), IEEE Computer Society, Los Alamitos, 124-34.